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AMENDMENTS TO THE CLAIMS 

1. (Currently amended) A method of determining a motional state of a mobile 
robot, the method comprising: 

retrieving pixel data for images taken at intervals from a camera that is coupled to 
the mobile robot; 

comparing pixel data for a first image to pixel data for a second image to generate 
a measure of a difference between the two images, wherein comparing comprises: 

filtering the first image pixel data with a gradient magnitude filter, where 
the gradient magnitude filter computes at least a spatial gradient; 

low-pass filtering the gradient magnitude filtered first image pixel data to 
generate a gradient-magnitude filtered smoothed first image pixel data; 

comparing the gradient-magnitude filtered first image pixel data to a first 
threshold; 

generating a binary map of the first image pixel data at least partly in 
response to the comparison of the gradient-magnitude filtered smoothed first 
image pixel data with the first threshold; 

filtering the second image pixel data with the gradient magnitude filter; 

low-pass filtering the gradient magnitude filtered second image pixel data 
to generate a gradient-magnitude filtered smoothed second image pixel data: 

comparing the gradient-magnitude filtered smoothed second image pixel 
data to a second threshold; 

generating a binary map of the second image pixel data at least partly in 
response to the comparison of the gradient-magnitude filtered second image pixel 
data to the second threshold; and 

comparing the binary map of the first image pixel data to the binary map 
of the second image pixel data to identify data for pixels that are different between 
the first image and the second image; 

using the comparison of the pixel data to count the number of pixel data identified 
as changed; 
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comparing the count to a third predetermined threshold; 

determining the motional state of the mobile robot at least partly in response to the 
count; and 

automatically providing an indication to a user that an undesired stoppage of the 
mobile robot has occurred if: 

the motional state of the mobile robot indicates that the mobile robot is not 
in motion; and 

the mobile robot is intended to be in motion, 

2. (Original) The method as defined in Claim 1 , wherein the method is performed in 
real time. 

3. (Currently amended) The method as defined in Claim 1, wherein the gradient 
magnitude filter further comprises a low-pass filter such that the gradien t magnitude filter 
computes both the spatial gradient and the low-pass -filtering for smoothing . 

4. (Original) The method as defined in Claim 3, wherein the low-pass filter 
corresponds to a Gaussian filter. 

5. (Original) The method as defined in Claim 3, wherein filtering the first image 
pixel data further comprises: 

filtering the first image pixel data in a first direction and in a second direction 
with a gradient filter that is characterized by the following convolution kernel, 
[.1 _4 -5 o 5 4 1] / 32, where results of filtering are separately maintained for the first 
direction and for the second direction; and 

combining the separately maintained data by computing a magnitude of the data. 

6. (Original) The method as defined in Claim 1, further comprising low-pass 
filtering image pixel data prior to computing a gradient. 

7. (Original) The method as defined in Claim 6, wherein a low-pass filter is 
characterized by the following convolution kernel: [1 4 6 4 1]/ 16; and a gradient filter is 
characterized by the following convolution kernel: [-1 0 1] / 2. 
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8. (Canceled) 

9. (Original) The method as defined in Claim 1 , further comprising: 

receiving an indication that the mobile robot is intended to be in motion in a first 
direction; 

determining that the motional state of the mobile robot is not in motion while 
receiving the indication that the mobile robot is intended to be in motion; and 

changing a path of travel for the mobile robot at least partly in response to the 
determination. 

10. (Original) The method as defined in Claim 1, further comprising subsampling the 
pixel data such that fewer than all the available pixels from the camera are used. 

11. (Original) The method as defined in Claim 1, wherein the third predetermined 
threshold varies at least partly in response to a number of pixels used to compute the count. 

12. (Original) The method as defined in Claim 1, wherein the first threshold and the 
second threshold are adaptive to filtering by the gradient magnitude filter of the first image pixel 
data and the second image pixel data, respectively. 

13. (Original) The method as defined in Claim 12, wherein the first threshold is 
selected to be about half the maximum value for the gradient magnitude computed for a pixel by 
the gradient magnitude filter after filtering of the first image pixel data, and where the second 
threshold is selected to be about half the maximum value for the gradient magnitude computed 
for a pixel by the gradient magnitude filter after filtering of the second image pixel data. 

14. (Original) The method as defined in Claim 1, wherein the comparison of the 
binary map of the first image pixel data to the binary map of the second image pixel data 
comprises a sloppy exclusive-or (XOR) computation. 

15. (Original) The method as defined in Claim 14, wherein the sloppy XOR is 
computed by comparing a pixel from the binary map of the first image pixel data with a location 
of (x,y) to a plurality of pixels in the binary map of the second image pixel data, wherein the 
plurality of pixels includes a pixel with a location of (x,y). 

16. (Original) The method as defined in Claim 1, wherein the motional state is 
determined only with observation of visual data. 
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17. (Original) The method as defined in Claim 1, where the mobile robot is 
autonomous, and where the method is performed entirely within the mobile robot, 

18. (Original) The method as defined in Claim 1 , further comprising: 
sending pixel data from the mobile robot to a remote computer; 
performing at least part of filtering operations in the remote computer; and 
receiving an indication of the motional state of the mobile robot from the remote 

computer. 

19. (Previously presented) A method of determining a motional state of a mobile 
robot, the method comprising: 

receiving pixel data for video images, where the video images are taken from a 
camera mounted to the mobile robot; 

processing the pixel data for the video images to identify amounts of spatial 
gradient within a video image; 

characterizing pixels of a video image into at least a first group and a second 
group, wherein the pixels of the first group correspond to a higher spatial gradient than 
the pixels of the second group; 

using the characterization of the pixels to compare a first video image to a second 
video image to detect the motional state of the mobile robot, wherein the motional state is 
selected from a set of possible motional states, the set comprising at least "in motion" and 
"not in motion;" and 

automatically providing an indication to a user that an undesired stoppage of the 
mobile robot has occurred if: 

the motional state of the mobile robot indicates that the mobile robot is not 
in motion; and 

the mobile robot is intended to be in motion. 

20. (Original) The method as defined in Claim 19, wherein characterizing further 
comprises: 

arranging the pixels of a video image into a binary map such that a first logic state 
indicates association with the first group with the higher spatial gradient; and 
a second logic state indicates association with the second group. 
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21 . (Original) The method as defined in Claim 20, wherein using the characterization 
comprises: 

comparing a binary value for one pixel. from the binary map of the first image to a 
group of binary values for a group of pixels in the second image; 

wherein the group of pixels in the second image includes a pixel in the same 
location as the one pixel from the binary map of the first image. 

22. (Original) The method as defined in Claim 21 , where comparing the binary value 
to the group of binary values further comprises computing a sloppy Exclusive-OR ("sloppy 
XOR") operation between the binary value and the group of binary values. 

23. (Original) The method as defined in Claim 19, further comprising: 

inspecting pixel data to evaluate whether enough useful spatial gradients exist for 
robust detection of the motional state; and 

inhibiting a motional state of "not moving" at least partly in response to a 
determination that the detection of the motional state is not likely to be reliable. 

24. (Original) The method as defined in Claim 19, wherein the motional state is 
determined only by analysis of visual data observed by the camera. 

25. (Original) The method as defined in Claim 19, where the mobile robot is 
autonomous, and where the method is performed entirely within the mobile robot. 

26. (Original) The method as defined in Claim 19, further comprising: 
sending pixel data from the mobile robot to a remote computer; 

performing at least part of pixel characterizing operations in the remote computer; 

and 

receiving an indication of the motional state of the mobile robot from the remote 
computer. 

27. (Currently amended) A method of controlling a behavior of a mobile robot 
based on a mismatch between an intended motional state and a perceived motional state in a 
mobile robot, the method comprising: 

receiving an indication of the intended motional state, where the motional state is 
selected from the group including moving and not moving; 
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using visual data from a camera that is coupled to the mobile robot to perceive the 
motional state of the mobile robot, where the perceived motional state of the mobile robot 
is selected from the group including moving and not movin g, wherein the mobile robot 
uses simultaneous localization and mapping ( SLAM) te chniques for navigation ; 

comparing the intended motional state to the perceived motional state to detect 
whether a mismatch exists between the intended motional state and the perceived 
motional state; and 

automatically changing the behavior of the mobile robot at least partly in response 
to a detected mismatch if: 

the intended motional state of the mobile robot indicates that the mobile 
robot is moving; and 

the perceived motional state of the mobile robot indicates that the mobile 
robot is not moving. 

28. (Original) The method as defined in Claim 27, wherein the intended motional 
state is moving, where changing the behavior comprises changing a navigated path, further 
comprising: 

instructing the mobile robot to travel in a direction approximately opposite to that 
previously requested for at least a distance sufficient to clear an obstruction; 
instructing the mobile robot to yaw; and 
instructing the mobile robot to resume traveling. 

29. (Original) The method as defined in Claim 27, wherein the intended motional 
state is moving, and where changing the behavior comprises shutting off motors to conserve 
battery life. 

30. (Original) The method as defined in Claim 27, wherein the mobile robot further 
comprises floor cleaning brushes, wherein changing the behavior further comprises shutting off 
cleaning brushes. 

3L (Original) The method as defined in Claim 27, wherein the mobile robot further 
comprises a vacuum cleaner, wherein changing the behavior further comprises shutting off the 
vacuum cleaner. 
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32. (Original) The method as defined in Claim 27, wherein the intended motional 
state is moving, and where changing the behavior comprises setting an alert. 

33. (Canceled) 

34. (Currently amended) The method as defined in Claim 27, whoroin the mobil e 
robot uG e s simultan e ous localization and mapping (SLAM) t e chniques for navigation, wher e th e 
intondod motional ctato io not moving, wherein changing the behavior comprises: 

resetting an estimate of pose (location and heading); and 

disabling mapping functions for recognition of new landmarks until localization is 
achieved. 

35. (Canceled) 

36. (Canceled) 

37. (Currently amended) The method as defined in Claim 27, wh o roin the mobile 
robot uo e s Gimultonoouc localization and mapping (SLAM) techniques for navigation, whore the 
intend e d motional G tato i s not moving^ wherein changing the behavior comprises disabling 
mapping functions for recognition of new landmarks until passage of a predetermined amount of 
time. 

38. (Original) The method as defined in Claim 37, wherein changing the behavior 
further comprising resetting an estimate of pose, including location and heading. 

39. (Currently amended) The method as defined in Claim 27, whor o in tho mobile 
robot uses Gimultan e ouo localization and mapping (SLAM) techniques for navigation, where th e 
int e nd e d motional state is not moving; wherein changing the behavior comprises disabling 
mapping functions for recognition of new landmarks until a predetermined number of unmatched 
landmarks have been observed. 

40. (Original) The method as defined in Claim 39, wherein changing the behavior 
further comprising resetting an estimate of pose, including location and heading. 

41. (Original) The method as defined in Claim 27, wherein the intended motional 
state is moving, where changing the behavior comprises: 

using the indication to determine that the mobile robot has been knocked over; 

and 

initiating procedures to restore the mobile robot to an upright position. 
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42. (Original) The method as defined in Claim 27, wherein the motional state is 
perceived using only the visual data from the camera. 

43. (Original) The method as defined in Claim 27, where the mobile robot is 
autonomous, and where the method is performed entirely within the mobile robot. 

44. (Original) The method as defined in Claim 27, further comprising: 
transferring visual data from the mobile robot to a remote computer; 
performing at least part of filtering operations in the remote computer; and 
transferring an indication of the perceived motional state of the mobile robot from 

the remote computer. 

45. (Canceled) 

46. (Canceled) 

47. (Canceled) 

48. (Canceled) 

49. (Original) A method of detecting that a mobile robot has been kidnapped, the 
method comprising: 

receiving an indication that the mobile robot is not instructed to be moving; 

receiving data for video images from a camera coupled to the mobile robot; 

comparing data from different video images to determine whether or not the 
mobile robot is in motion; and 

determining that the mobile robot has been kidnapped when the video images 
indicate that the mobile robot is in motion. 

50. (Previously presented) A circuit for a mobile robot that is configured to 
determine a motional state of the mobile robot, the circuit comprising: 

a means for receiving pixel data for video images, where the video images are 
taken from a camera mounted to the mobile robot; 

a means for processing the pixel data for the video images to identify amounts of 
spatial gradient within a video image; 

a means for characterizing pixels of a video image into at least a first group and a 
second group, wherein the pixels of the first group correspond to a higher spatial gradient 
than the pixels of the second group; and 
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V 

a means for using the characterization of the pixels to compare a first video image 
to a second video image to detect the motional state of the mobile robot, wherein the 
motional state is selected from a set of possible motional states, the set comprising at 
least 4t in motion'* and 4t not in motion;" 

a means for automatically providing an indication to a user that an undesired 
stoppage of the mobile robot has occurred if: 

the motional state of the mobile robot indicates that the mobile robot is not 
in motion, and 

the mobile robot is intended to be in motion. 

51. (Canceled) 

52. (Canceled) 

53. (Previously presented) The method as defined in Claim 19, wherein processing 
the pixel data further comprises processing the pixel data to identify amounts of spatial gradient 
within the entire video image. 
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